table of contents
PTHREAD_ATFORK(3) | Manuel du programmeur Linux | PTHREAD_ATFORK(3) |
NOM¶
pthread_atfork - enregistre des gestionnaires à invoquer lors de l'appel à fork(2)
SYNOPSIS¶
#include <pthread.h>
int pthread_atfork(void (*prepare)(void), void (*parent)(void), void (*child)(void));
DESCRIPTION¶
pthread_atfork() enregistre les fonctions à appeler juste avant et juste après la création d'un nouveau processus par fork(2). Le gestionnaire prepare est appelé par le processus parent juste avant la création du nouveau processus. Le gestionnaire parent est appelé par le processus parent juste avant que fork(2) finisse. Le gestionnaire child est appelé par le processus fils juste avant la fin de l'appel fork(2).
L'un ou plusieurs des trois gestionnaires prepare, parent et child peut être affecté à NULL, ce qui signifie qu'aucun gestionnaire ne sera appelé au moment correspondant.
pthread_atfork peut être appelée plusieurs fois pour enregistrer plusieurs ensembles de gestionnaires. Lors de l'appel à fork(2), les gestionnaires prepare sont appelés dans l'ordre LIFO (Last In First Out : dans l'ordre inverse de l'enregistrement) juste avant fork(2), alors que les gestionnaires parent et child sont appelés dans l'ordre FIFO (First In First Out : dans l'ordre d'enregistrement).
Pour comprendre l'objectif de pthread_atfork(), rappelons que fork(2) copie toute l'image mémoire du processus, y compris ses mutexes dans leur état de bloquage courant, mais seulement le thread courant : les autres threads ne s'exécutent pas dans le processus fils. Les mutexes ne sont pas utilisables après le fork(2) et doivent être initialisés avec pthread_mutex_init(3) dans le processus fils. C'est une limitation de l'implémentation actuelle et peut être ou ne pas être présente dans les prochaines versions.
VALEUR RENVOYÉE¶
pthread_atfork() retourne 0 en cas de succès et un code d'erreur non nul en cas d'erreur.
ERREURS¶
- ENOMEM
- Pas assez de mémoire disponible pour enregistrer les gestionnaires.
AUTEUR¶
Xavier Leroy <Xavier DOT Leroy AT inria DOT fr>
VOIR AUSSI¶
TRADUCTION¶
Ce document est une traduction réalisée par Thierry Vignaud <tvignaud AT mandriva DOT com> en 2000 et révisée le 19 novembre 2007.
L'équipe de traduction a fait le maximum pour réaliser une adaptation française de qualité. La version anglaise la plus à jour de ce document est toujours consultable via la commande : « LANG=C man 3 pthread_atfork ». N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.
14 décembre 2001 | LinuxThreads |